# JoSIM - Superconducting Circuit Simulator

Developers Manual v1.0

Johannes A. Delport

Stellenbosch University South Africa April 30, 2018

### Copyright © 2017-2018 by Johannes Delport

Permission is granted to anyone to make or distribute verbatim copies of this document as received, in any medium, provided that the copyright notice and the permission notice are preserved, and that the distributor grants the recipient permission for further redistribution as permitted by this notice

Linux is a registered trademark of Linus Torvalds.

Windows is a registered trademark of Microsoft Corporation.

macOS is a registered trademark of Apple, Inc.

All trademarks are the property of their respective owners.

## Contents

| T             | ıntr          | oduction and setup                             | 1        |
|---------------|---------------|------------------------------------------------|----------|
|               | 1.1           | Introduction                                   | 1        |
|               | 1.2           | Initial setup                                  | 1        |
|               | 1.3           | License                                        | 2        |
|               | 1.4           | Building from source                           | 2        |
|               |               | 1.4.1 UNIX                                     | 2        |
|               |               | 1.4.2 Windows                                  | 2        |
| 2             | Tecl          | hnical discussion                              | 3        |
|               | 2.1           | Modified nodal analysis                        | 3        |
|               | 2.2           | Trapezoidal integration                        | 3        |
|               | 2.3           | LU decomposition                               | 5        |
|               | 2.4           | Data structures & speed considerations         | 5        |
|               | 2.5           | FLTK                                           | 6        |
| 3             | Inp           | ut files                                       | 7        |
| 4             | Con           | nmand line arguments/switches                  | 7        |
| 5             | Out           | put                                            | 8        |
|               | 5.1           | Comma seperated value                          | 8        |
|               | 5.2           | Space seperated value                          | 8        |
|               | 5.3           | GUI plotting window                            | 8        |
| 6             | Exa           | mples                                          | 9        |
| 7             | Erro          | or handling and exceptions                     | 12       |
| 8             | Plai          | nned improvements                              | 12       |
| ${f A}_{f J}$ | open          | dices 1                                        | 13       |
| ٨             | Con           | nponent Stamps 1                               | 13       |
| <b>A</b>      |               | 1                                              | 13       |
|               | A.1<br>A.2    |                                                | 13       |
|               | A.2<br>A.3    | •                                              | 13<br>14 |
|               | A.3<br>A.4    |                                                | 14<br>14 |
|               | A.4<br>A.5    |                                                | 15       |
|               | A.6           |                                                | 16       |
|               | $\Lambda . U$ | TIMINIONI III II | τU       |

### 1 Introduction and setup

### 1.1 Introduction

JoSIM was developed under IARPA contract SuperTools(via the U.S. Army Research Office grant W911NF-17-1-0120). JoSIM is a analogue circuit simulator with SPICE syntax input that has inherent support for the superconducting Josephson junction element.

JoSIM is meant to function as a replacement to the aging simulator JSIM[1]. JoSIM is written in modern C++ and is fully customizable and extendable to offer support for improved superconducting elements as well better approximations to the Josephson effect in superconducting materials.

A .cir or .js file containing a SPICE syntax circuit netlist is provided as input. The circuit netlist, given appropriate input excitations can then be simulated through transient analysis. Results of this simulation can be either plotted for quick reference or saved as either a space delimited (.dat) or a comma separated value (.csv) file.

Fig.1 shows an overview of what JoSIM aims to accomplish. This is much like any other SPICE deck simulator with the exception that it incorporates native handling of the Josephson junction.



Figure 1: A macro overview of JoSIM

#### 1.2 Initial setup

JoSIM can be found at JoSIM.git from where it can be cloned and compiled for either UNIX or Windows. Within this repository there will be a **CMakeLists.txt** which is a recipe used to compile JoSIM using CMake.

To compile the source a working C++ compiler with support for C++17 is required. FLTK (Fast Light Toolkit) is also required to display the results when the plotting option is enabled. Additionally SuiteSparse linear algebra libraries are required but are provided on the repository. Git version control software is recommended but is not required to compile JoSIM.

A single executable binary is generated using the CMake recipe and can be placed anywhere on the system as well as freely redistributed.

#### 1.3 License

JoSIM is governed by the MIT license which is a very permissive license that allows anyone to redistribute it as well as commercialize it without repercussions. The MIT license allows use of this software within proprietary software as long as all copies of the licensed software includes a copy of the MIT license as well as the copyright notice.

### 1.4 Building from source

#### 1.4.1 UNIX

To compile the software from source ensure that FLTK and CMake is installed if on a UNIX system. Open a terminal and navigate a to a directory where compilation will take place.

Execute the following command:

```
$ git clone https://github.com/JoeyDelp/JoSIM.git
```

or navigate to the above link and download the repository as a .tar.gz archive and extract it to the chosen directory. Navigate to the newly cloned/extracted JoSIM directory then run the following commands:

- \$ mkdir build
- \$ cd build
- \$ cmake ..
- \$ make

This will generate a JoSIM executable in the *bin* folder for either Linux or mac depending on the UNIX system.

### 1.4.2 Windows

A Microsoft Visual Studio solution is provided and can be found in the *src* folder. This is by far the easiest way to compile the software under a Microsoft Windows environment. Simply open the solution and click build (F6) to build either Debug or Release targets for the software.

The executable can be found under bin/win followed by the chosen configuration.

### 2 Technical discussion

### 2.1 Modified nodal analysis

There are many ways to set-up a set of linear equations to solve the voltage or currents in a circuit. One of the more well known ways is to use nodal analysis which creates an equation for each node defined in the circuit netlist. This method is the basis on which the original Berkeley SPICE[2] was built. This method however only calculates the voltages of every node which makes it difficult to handle components that are voltage dependent such as inductors and junctions.

This drawback lead to the creation of the modified nodal analysis which is an extension to the prior with the ability of calculating some of the branch currents in the circuit.[3] We therefore make use of the MNA to build the set of linear equations within JoSIM due to the large use of inductors as well as Josephson junctions in superconductivity.

Another useful feature of MNA is the way that every component can be represented as a sub-matrix we call a stamp. The summation of all the stamps provide us with the A, x as well as b matrices that are required to solve the linear equations. These stamps will be discussed further in the following subsection.

### 2.2 Trapezoidal integration

Much like the nodal analysis mentioned before, there are multiple methods of solving differential equations with minimal error in a digital system. The most basic method is the forward Euler method which is a first-order approximation method where the error is proportional to the step size.[4]. Solving differential equations however produce a local truncation error which is the difference between the numerical solution and the exact solution after one step. It can be shown that the local truncation error for the forward Euler method is proportional to the square of the time step taken which makes this method less accurate compared to higher order methods.

We focus rather on using the trapezoidal rule for solving the linear equations as this method becomes increasingly more accurate as the time steps become smaller. The trapezoidal rule is a second-order method for solving differential equations. We can express the trapezoidal method as:

$$\left(\frac{dx}{dt}\right)_n = \frac{2}{h_n} \left(x_n - x_{n-1}\right) - \left(\frac{dx}{dt}\right)_{n-1} \tag{1}$$

In this case the n is the current time step and n-1 refers to the previous time step. By using this method to solve differential equations we are able to create generic stamps for each component that JoSIM can handle.

To demonstrate this method and how a stamp is formed we will show an example of an



Figure 2: A basic inductor with current flowing through it

inductor. The inductor in Fig.2 has a general equation to determine the voltage across it as:

$$v_{L1}(t) = L1 \frac{di}{dt} \tag{2}$$

When we apply the trapezoidal rule we find (2) can be rewritten as:

$$v_{n} = L1 \left[ \frac{2}{h_{n}} (I_{n} - I_{n-1}) - \left( \frac{di}{dt} \right)_{n-1} \right]$$

$$= \frac{2L1}{h_{n}} (I_{n} - I_{n-1}) - L1 \left( \frac{di}{dt} \right)_{n-1}$$

$$= \frac{2L1}{h_{n}} (I_{n} - I_{n-1}) - v_{n-1}$$

$$\therefore I_{n} = \frac{h_{n}}{2L1} (V_{n} + V_{n-1}) + I_{n-1}$$
(4)

$$\therefore \frac{h_n}{2L!} V_n - I_n = -\frac{h_n}{2L!} V_{n-1} + I_{n-1}$$
(5)

Where (5) is the current step voltage and current as a function of the previous step values. We further expand the (5) by stating that the voltage is the potential across the two nodes:  $v = v_1 - v_2$ .

$$\frac{h_n}{2L1}(V_1)_n - \frac{h_n}{2L1}(V_2)_n - I_n = -\left(\frac{h_n}{2L1}V(V_1)_{n-1} - \frac{h_n}{2L1}(V_2)_{n-1}\right) - I_{n-1}$$
 (6)

Which we can then write in matrix form as:

$$\begin{bmatrix} 0 & 0 & 1 \\ 0 & 0 & -1 \\ 1 & -1 & \frac{-2L1}{h_n} \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \\ I_{L1} \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ -\frac{2L1}{h_n} (I_{L1})_{n-1} - ((V_1)_{n-1} - (V_2)_{n-1}) \end{bmatrix}$$
(7)

(7) is a generic stamp that we can place into the A matrix which describes the inductor L1.

We can do the same for a resistor, capacitor, current source, voltage source, Josephson junction and a transmission line. The stamps for each of these components can be found in Appendix

### 2.3 LU decomposition

When the A matrix has been set up as detailed in the previous section all that is left to do is to solve the Ax = b problem using some form of iterative method. We choose KLU from the SuiteSparse[5] library to accomplish this task.

This requires the A matrix to be in compressed row storage (CRS) format which is a data structure of 3 vectors. The first of these vectors contains all the non-zero elements in the A matrix. The second contains first a 0 followed the total number of non-zero elements after each row such that the final entry in the vector is the total number of non-zero elements. The third vector contains the column index of each non-zero element. As an example, the following sparse matrix of 5x5

$$\begin{bmatrix} 1 & 0 & 0 & 4 & 0 \\ 0 & 3 & 2 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 4 & 0 & 5 & 0 \\ 0 & 0 & 0 & 0 & 1 \end{bmatrix}$$

would yield a CSR format data structure of

$$nnz = [1, 4, 3, 2, 1, 4, 5, 1]$$

$$rowptr = [0, 2, 4, 5, 7, 8]$$

$$colind = [0, 3, 1, 2, 2, 1, 3, 4]$$

which has a total of 21 elements compared to the 25 required for the original A matrix. This difference of course becomes much larger the larger the A matrix becomes as well as the sparser the matrix becomes. Which is almost always the case for electrical type simulations.

Once in this format we can proceed with the KLU factorization. Due to the MNA forcing only the RHS to change upon every time step we can easily do the LU decomposition for the A matrix only once at the beginning of the time loop. Where after the system is simply solved using with a new RHS upon each iteration.

#### 2.4 Data structures & speed considerations

JoSIM relies heavily on the use of the C++ unordered map data structure which creates a hash table for quick lookup. This immensely simplifies code legibility as well as component identification within later stages of the process.

Initially a standard map was used, however this very negatively impacted the speed of execution of the program and thus alternatives were sought. Ideally the use of unordered maps are not perfect if speed was the only consideration, however they do provide a good balance between implementation, speed and debugging.

There is still large room for improvement with regards to parallel processing of specific stages within the execution, however the largest part of the process (the time loop) is very loop dependent and therefore cannot be parallel processed. This also limits the speed improvement to relatively large circuits as the overhead required for thread delegation slows down the execution on smaller problems.

#### 2.5 FLTK

JSIM lacked the ability to provide direct feedback on the results of the simulation. Unless the user had some script to plot the data file that it produced or some third-party application that could plot the results no clear feedback was received.

With JoSIM we introduce the implementation of the cross-platform C++ GUI library FLTK[6] which allows the results of the simulation to be instantly plotted in a data graph window. Though the full extent of the FLTK library has not been explored. The current implementation acts as a proof-of-concept design.

### 3 Input files

Input files follow a SPICE syntax similar to JSIM. This allows for a direct use of the files that are already executable using JSIM as well as tools that write output files for use with JSIM.

Each SPICE file (.cir or .js) can be broken into subsections such as comments, subcircuits, main circuit and control sections. Each individual line is categorized by the first character. This is key to the efficiency of the entire tool as that single first character defines what the program does with that line as the file is read in line by line.

An example of a input file is given in the example section of this document.

### 4 Command line arguments/switches

Example command: josim -g -o ./output.csv test.cir

A full range of the available command switches and their arguments is provided to the user upon specification of the -h switch.

```
[Joeys-MacBook-Pro:release joeydelport$ ./JoSIM -h
JoSIM: Josephson Junction Superconductive SPICE Circuit Simulator
Copyright (C) 2017 by Johannes Delport (jdelport@sun.ac.za)
Help menu for JoSIM
______
-g
          Plot the requested results with FLTK plotting window
          If this is enabled with VERBOSE mode then all traces are plotted
-h
          Displays this help menu
          Specify output file for simulation results (.csv)
-0
          Default will be output.csv if no file is specified
          [Legacy] JSIM N output file format (.dat)
-m
          Default will be output.dat if no file is specified
          Runs JoSIM in verbose mode
```

Figure 3: JoSIM help command menu

Each help menu item is pretty self explanatory and should not require further documentation. These command switches can be placed in any order and can be concatenated so long as the final command is the input file.

### 5 Output

### 5.1 Comma seperated value

The output to a comma separated value format file was chosen due to the large support therefore and ease of import into third-party tools such as Microsoft Excel. This simplifies the movement, copying and removal of columns from the output file a lot simpler as well.

### 5.2 Space seperated value

This is the legacy format that JSIM uses to output it's results into. We opt to support this file format due to the large user base of JSIM and the amount of plotting/viewing tools written around this output format. This output format can also be easily read in and manipulated by third party tools and we shall therefore keep this option with the same command switch as JSIM.

### 5.3 GUI plotting window

The output of results directly into a plotting window that is user viewable improves the prototyping speed immensely as the user can immediately see whether the output is as desired or not. Though primitive at present with the lack of any axis or tooltips to show that the values of each graph are as well as the lack of the ability to resize the graphs within the window, we will continue to expand on this functionality to eventually have a user-friendly output window.

### 6 Examples

Below is an example file that Chains together a DCSFQ, 3 x JTLs and a SINK cell.

```
\begin{array}{ll} jj1 & \text{area} = 2.16 \\ jj1 & \text{area} = 2.16 \\ pwl (0 \ 0 \ 5p \ 280u) \end{array}
       B02
       IB01
                          0
 4
5
6
       L01
L02
                                                                  2.031p
2.425p
                          4
3
                                              3 2
       L03
L04
                                                                  2.425p
2.031p
                          2
6
                                              6
5
7
8
       LP01
LP02
                                                                  0.086p
0.086p
10
11
12
       LPR01
                          \frac{2}{7}
                                                                  0.278p
       LRB01
                                               9
                                                                  1p
13
       LRB02
                                               10
       RB01
14
                           10
15
       RB02
                                              6
                                                                  5.23
                          jj (rtype=1, vg=2.8mV, cap=0.07pF, r0=160, rn=16, icrit=0.1mA)
16
       . model jj1
        ends JTL
SUBCKT DCSFQ 2 17
17
18
                                                                  јј1
јј1
19
       B01
                                                                               area = 1.32
                          5
5
9
       B02
                                                                               area=1
20
21
22
23
       B03
                                               10
                                                                  jj1
jj1
jj1
                                                                              area=1.5
area=1.96
       B04
                           13
                                               14
                           15
                                                                  jj1 area=1.96
pwl(0 0 5p 162.5u)
       B05
                                               16
                                                                  pwl(0 0 5p 162.5
pwl(0 0 5p 260u)
0.848p
7.712p
1.778p
                                               12
25
       IB02
                          _2^0
26
       L01
       ^{\rm L02}_{\rm L03}
27
                          _{1}^{0}
29
       L04
                          5
7
9
                                                                  0.543p
       L05
                                                                  3.149p
31
                                               11
       L06
                                                                  1.323p
                                                                  1.095p
2.951p
       L07
       L08
                           13
                                               15
33
       L09
                           15
                                               17
                                                                  1.63p
35
       LP01
                          _{0}^{0}
                                              ^6_{10}
                                                                  0.398p
       LP02
LP03
                                                                  0.211p
0.276p
37
                          0
                                               14
38
39
       LP04
LPR01
                                                                  0.224p
0.915p
                                               16
                                               8
       LPR02
LRB01
                                                                  0.307p
                           11
                                               12
41
                                                                  1p
42
43
       LRB02
LRB03
                          18
19
                                              6
10
                                                                  1p
       \begin{array}{c} LRB04 \\ LRB05 \end{array}
                          \frac{20}{21}
44
                                               14
                                               16
45
                                                                  1p
                          3
18
19
                                                                  8.56
11.30
7.53
5.77
5.77
\frac{46}{47}
       RB01
                                               4
       RB02
48
       BB03
                                               9
49
       RB04
                           20
                                               13
50
51
       RB05
                          21
jj (
                                               15
       . model jj1
. ends DCSFQ
                                  type=1, vg=2.8mV, cap=0.07pF, r0=160, rn=16, icrit=0.1mA)
\frac{52}{53}
        SUBCKT SINK 2
                                                                  jj1 area=2.16
pwl(0 0 5p 280u)
0.517p
5.307p
54
55
       B01
       IB01
                                              5
1
56
                          2
       L01
       L02
58
       LP01
                          0
                                               4
                                                                  0.086p
59
       LPR01
                                                                  0.265p
                                                                  ^{1\,\mathrm{p}}_{5\,.\,2\,3}
60
       LRB01
                                              6
       ROUT
62
                          0
                                              3
                                                                  4.02
      jj(rtype=1, vg=2.8mV, cap=0.07pF, r0=160, rn=16, icrit=0.1mA)
64
                                                       600\mathtt{u}\ 182\mathtt{p}\ 0\ 370\mathtt{p}\ 0\ 376\mathtt{p}\ 600\mathtt{u}\ 382\mathtt{p}\ 0\ 600\mathtt{p}\ 0\ 606\mathtt{p}\ 600\mathtt{u}\ 612\mathtt{p}\ 0\ 700\mathtt{p}\ 0
                          DCSFQ
                                                                      2
                          JTL
67
       X02
                                                                      3
4
5
       X03
                          _{
m JTL}
                                                    3
       X04
                          JTL
69
70
71
       X05
                          SINK
       tran 0.25p 1000p 0 0.25p
print nodev 1 0
print nodev 2 0
73
74
75
                   nodev 3 0
nodev 4 0
       . print
       .print
       print nodev 5 0
```

This file can be found under  $JoSIM/test/dcsfq\_jlt\_sink.js$  and we will now demonstrate this example using JoSIM.

```
[Joeys-MacBook-Pro:release joeydelport$ ./JoSIM -g -o ../../test/dcsfq_jtl_sink.js
JoSIM: Josephson Junction Superconductive SPICE Circuit Simulator
Copyright (C) 2017 by Johannes Delport (jdelport@sun.ac.za)
Path specified for input file: ../../test/dcsfq_jtl_sink.js
Input file specified as: dcsfq_jtl_sink.js
Circuit characteristics:
                                  3
Subcircuits:
DCSFQ component count:
                                  32
DCSFQ JJ count:
JTL component count:
JTL JJ count:
                                  2
SINK component count:
                                  9
SINK JJ count:
                                  1
Main cicuit component count:
                                  84
Main cicuit JJ count:
                                  12
Simulating:
100%[=========]
```

Figure 4: JoSIM command line window output from execution of the dcsfq\_jtl\_sink.js

Fig 4 shows the default output from the JoSIM executable produces some statistics about the file provided as input and the reuse of subcircuits within the file. It also gives the user a cout of the amount of Josephson junctions used within the circuit as this is usually taken as a measure of how large the circuit is.

The results of the -g command switch can be seen in Fig 5. Which we can clearly see from is the results expected given the type of circuit. The 3 graphs that are plotted are the node voltages at the input to the DCSFQ, the middle JTL and the output SINK.



Figure 5: JoSIM FLTK results window from execution of the dcsfq\_jtl\_sink.js file

There are a few larger examples included in the test folder which can be executed to test the execution speed of JoSIM.

### 7 Error handling and exceptions

An attempt is made to handle as many of the exceptions thrown as possible and to provide the user with accurate and meaningful error messages in the case of an error. If any issues are not caught or bugs are picked up during the usage of JoSIM, please do not hesitate to report them on the git page under issues. The software has had very little exposure until now. It is a version 1 tool and there will be bugs, please use with caution and please report any issues.

### 8 Planned improvements

There are several planned improvements to JoSIM which include the use of the .options command to enable parameterized variables for which the functions can be specified to determine values.

Per device temperature dependence as well as global temperature will be implemented to more accurately model the effects of superconductive materials.

Improved FLTK output window with controls to zoom and tooltips to show values as well as x- and y-axis labels. Further implementation will include the ability to save the results to an scalar vector graphic (SVG) for publication grade graphics.

Engine improvements will include new Josephson junction models that extend beyond the default RCSJ model, as well as the ability to do phase based simulation will usher in the ability to simulate the Werthamer approximated model for the Josephson junction. Further engine improvements will also include parallel processing of certain stages within the execution as well as the ability to switch to different linear solvers.

## **Appendices**

### A Component Stamps

#### A.1 Resistor



Figure 6: A basic resistor with current flowing through it

$$v_{R1}(t) = i_{R1}(t)R1$$

$$(V_1 - V_2)_n = I_nR1$$

$$\frac{1}{R1}(V_1)_n - \frac{1}{R1}(V_2)_n - I_n = 0$$
(8)

We however do not need to calculate the current through the Resistor as it is not always needed, we therefore omit it in the matrix and calculate it when the user requests it.

$$\begin{bmatrix} \frac{1}{R} & -\frac{1}{R} \\ -\frac{1}{R} & \frac{1}{R} \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \end{bmatrix}$$

### A.2 Capacitor



Figure 7: A basic capacitor with current flowing through it

$$i_n(t) = C1 \frac{dv}{dt}$$

$$i_n(t) = \frac{2C1}{h_n} \left[ (V_n - V_{n-1}) - \left( \frac{di}{dt} \right)_{n-1} \right]$$

$$\frac{2C1}{h_n} (V_1)_n - \frac{2C1}{h_n} (V_2)_n - I_{(n)} = \frac{2C1}{h_n} (V_1 - V_2)_{n-1} + I_{n-1}$$
(9)

Once again we omit the current for the capacitor as it will only complicate the calculation. We therefore only calculate the voltage output.

$$\begin{bmatrix} \frac{C}{h_n} & -\frac{C}{h_n} \\ -\frac{C}{h_n} & \frac{C}{h_n} \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \end{bmatrix} = \begin{bmatrix} \frac{C}{h_n} \\ -\frac{C}{h_n} \end{bmatrix}$$

### A.3 Voltage source



Figure 8: A basic voltage source

A voltage source simply adds the voltage as a new row and column to the matrix, similar to a branch current.

$$\begin{bmatrix} 0 & 0 & 1 \\ 0 & 0 & -1 \\ 1 & -1 & 0 \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \\ V1 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ V1 \end{bmatrix}$$

### A.4 Current source



Figure 9: A basic capacitor with current flowing through it

A current source does not affect the A matrix in any way and simply adds or subtracts the current supplied at the respective nodes.

$$\begin{bmatrix} 0 & 0 \\ 0 & 0 \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \end{bmatrix} = \begin{bmatrix} -I1 \\ I1 \end{bmatrix}$$

### A.5 Josephson junction



Figure 10: A basic Josephson junction



Figure 11: A basic Josephson junction in Resistively, Capacitively Shunted Junction form

$$I_s = -I_c \sin \phi_n^0 + \frac{2C}{h_n} v_{n-1} + C \left(\frac{dv}{dt}\right)_{n-1}$$

$$\tag{10}$$

In this case  $I_c$ , C,  $\phi_n^0$  are the junction critical current, capacitance and initial phase guess.

$$\phi_n^0 = \phi_{n-1} + \frac{h_n}{2} \frac{2e}{\bar{h}} (v_{n-1} + v_n^0)$$
(11)

$$v_{n}^{0} = v_{n-1} + h_{n} \left(\frac{dv}{dt}\right)_{n-1}$$

$$= v_{n-1} + h_{n} \left[\frac{2}{h_{n}} (v_{n-1} - v_{n-2}) - \left(\frac{dv}{dt}\right)_{n-2}\right]$$

$$v_{n}^{0} = 3v_{n-1} - 2v_{n-2} - h_{n} \left(\frac{dv}{dt}\right)_{n-2}$$
(12)

When we apply 12 to 11 we can approximate an equation for the initial phase guess. To approximate this we would need to specify values for 3 time steps before the first time step. By assuming these values are always 0 we can then implement this as a stamp.

$$\begin{bmatrix} \frac{2C}{h_n} + \frac{1}{R} & -\frac{2C}{h_n} - \frac{1}{R} & 0\\ -\frac{2C}{h_n} - \frac{1}{R} & \frac{2C}{h_n} + \frac{1}{R} & 0\\ -\frac{h_n}{2} \frac{2e}{h} & \frac{h_n}{2} \frac{2e}{h} & 1 \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \\ \phi \end{bmatrix} = \begin{bmatrix} I_s \\ -I_s \\ \phi_{n-1} + \frac{h_n}{2} \frac{2e}{h} v_{n-1} \end{bmatrix}$$

### A.6 Transmission line



Figure 12: A basic lossless transmission line

The implementation of a lossless transmission line requires the everything on the right-hand side to be delayed by the TD specified by the user. The Z0 is the line impedance and is a function of the transmission line length.

The voltage on between node 1 and 2 is delayed by TD before appearing at node 3 and 4, where after a reflection of the result at node 3 and 4 is observed at node 1 and 2. This effect continues every TD until the voltage is completely diminished by the line impedance.



Figure 13: A basic lossless transmission line broken into components

The dependent voltage sources on either side of the transmission line can be described by

$$V1T1(t) = [V_3(t - TD) - V_4(t - TD)] + Z0 \cdot i_2(t - TD)$$
(13)

$$V2T1(t) = [V_1(t - TD) - V_2(t - TD)] + Z0 \cdot i_1(t - TD)$$
(14)

where

$$i_1 = \frac{V_1 - V_5}{Z0} \tag{15}$$

$$i_1 = \frac{V_1 - V_5}{Z0}$$

$$i_2 = \frac{V_3 - V_6}{Z0}$$
(15)

$$\begin{bmatrix} \frac{1}{Z0} & -\frac{1}{Z0} & 0 & 0 & 0 & 0 & 0 & 0 \\ -\frac{1}{Z0} & \frac{1}{Z0} & 0 & 0 & 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & -1 & 0 \\ 0 & 0 & \frac{1}{Z0} & -\frac{1}{Z0} & 0 & 0 & 0 & 0 \\ 0 & 0 & -\frac{1}{Z0} & \frac{1}{Z0} & 0 & 0 & 0 & 1 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & -1 \\ 0 & 1 & -1 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 1 & -1 & 0 & 0 \end{bmatrix} \begin{bmatrix} V1 \\ V5 \\ V2 \\ V3 \\ V6 \\ V4 \\ V1T1 \\ V2T1 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ 0 \\ 0 \\ V1T1 \\ V2T2 \end{bmatrix}$$

### References

- [1] E. S. Fang and T. Van Duzer. A Josephson integrated circuit simulator (JSIM) for superconductive electronics application. Extended Abstracts of 1989 International Superconductivity Electronics Conference, 407-410, 1989.
- [2] Laurence W. Nagel and D.O. Pederson. SPICE (Simulation Program with Integrated Circuit Emphasis). EECS Department, University of California, Berkeley, 1973.
- [3] Ho, Ruehli, and Brennan. *The Modified Nodal Approach to Network Analysis*. Proc. 1974 Int. Symposium on Circuits and Systems, San Francisco. pp. 505509.
- [4] Atkinson, Kendall A. An Introduction to Numerical Analysis (2nd ed.) New York: John Wiley & Sons, 1989
- [5] Timothy A. Davis *Direct Methods for Sparse Linear Systems* SIAM, Philadelphia, Sept. 2006.
- [6] F. Costantini, D. Gibson, M. Melcher, A. Schlosser, B. Spitzak and M. Sweet. FLTK 1.4.0 Programming Manual. 2018. [Online]. Available: http://www.fltk.org/. [Accessed: 29- Apr- 2018].